草庐IT

sql - 在 SQL Server 中合并 XML

全部标签

sql - Rails 中独立于数据库的 SQL 字符串连接

我想在Rails查询中进行数据库端字符串连接,并以独立于数据库的方式进行。SQL-92指定双杠(||)作为连接运算符。不幸的是,MSSQLServer似乎不支持它;它使用+代替。我猜Rails的SQL语法抽象已经解决了特定于数据库的运算符问题。如果它确实存在,我该如何使用它? 最佳答案 我遇到了同样的问题,但从未想出任何内置于Rails中的东西。所以我写了这个小方法。#Symbolsshouldbeusedforfieldnames,everythingelsewillbequotedasastringdefdb_concat(*a

sql - 将每个 SQL 查询记录到 Rails 中的数据库

我想将某些SQL查询rails执行(即CREATE、UPDATE和DELETE)保存到日志文件中因此我需要拦截所有查询,然后可能使用一些正则表达式过滤它们并根据需要记录它们。我应该把这样的东西放在Rails代码的什么地方? 最佳答案 这里是c0r0ner链接的简化版本,以更好地展示它:connection=ActiveRecord::Base.connectionclasse;end#executeoriginalstatementoriginal_exec(sql,*name)endend

ruby - 如何使用 Sinatra 提供 XML 文档?

我有一些XML文档,我想从Sinatra服务器获取这些文档。我做了一些搜索,但找不到任何具体的东西。我确实找到了构建器gem,但我不想从头开始构建文档。我试着做这样的事情get'/'xml='Myname90'bodyxmlend但这会在它周围添加HTML标签。这可能是我所缺少的非常基本的东西。你能给我指出正确的方向吗? 最佳答案 这对于Sinatra来说非常简单:get'/'docontent_type'text/xml'"Luis99"end在获取“/”时,响应将是XML"Luis99"使用正确的content_type。

ruby - 尝试使用 nokogiri 获取 xml 文件中 cdata 标签内的内容

我已经看到了几件事,但到目前为止似乎没有任何效果。我正在使用nokogirionrails3ruby​​1.9.2通过url解析xml。xml的片段如下所示:我正在尝试解析它以获取与NewsLineText关联的文本r=node.at_xpath('.//newslinetext')ifnode.at_xpath('.//newslinetext')s=node.at_xpath('.//newslinetext').textifnode.at_xpath('.//newslinetext')t=node.at_xpath('.//newslinetext').contentifnod

ruby-on-rails - 如何呈现 XML 模板,然后在 Ruby on Rails 3.2.8 中使用 SEND_DATA?

谁能帮我处理XML模板渲染和发送数据?我有一个Controller:defshow@calculation=Calculation.find(params[:id])respond_todo|format|format.html#show.html.erbformat.json{renderjson:@calculation}format.xml{send_data(:partial=>show.xml.erb,:filename=>"my_file.xml")}format.pdf{render:format=>false}endend但是我有很多关于“堆栈级别太深”的错误如果我用{

ruby - 如何转义 Ruby 中的字符串以防止 SQL 注入(inject)? (无导轨)

我只是想知道我们如何在Ruby中转义SQL查询(字符串)以防止SQL注入(inject)。请注意我没有使用Rails框架。谢谢。 最佳答案 如果可能,请使用RubyDBI模块,而不是尝试引用您的字符串,而是使用参数化的准备查询,如下所示:dbh=DBI.connect("DBI:Mysql:test:localhost","testuser","testpass")sth=dbh.prepare("INSERTINTOpeople(id,name,height)VALUES(?,?,?)")File.open("people.txt

sql - 如何使用 Sequel 运行原始 SQL 查询

我还不清楚使用Sequel运行原始SQL查询的正确方法。目前我正在尝试这个:DB.fetch("SELECT*FROMzoneWHEREdialcode='#{@dialcode}'LIMIT1")do|row|@zonename=rowend我怎样才能将查询作为原始SQL运行,然后像平常一样访问结果?if@zonename.name="UK" 最佳答案 请注意,而不是:DB.fetch("SELECT*FROMzoneWHEREdialcode='#{@dialcode}'LIMIT1")你应该这样做:DB.fetch("SELE

ruby - 如何在 ruby​​ 中合并两个具有相同键的散列

我有两个散列,它们应该具有相同的键,例如:a={a:1,b:2,c:3}b={a:2,b:3,c:4}我想像这样总结每个值:ifa.keys==b.keysa.values.zip(b.values).map{|a,b|a+b}end但如果键的顺序不同,如b={a:2,c:4,b:3},此代码将不起作用。如何编写考虑到键顺序的代码? 最佳答案 使用Hash#merge或Hash#merge!:a={a:1,b:2,c:3}b={a:2,c:4,b:3}a.merge!(b){|k,o,n|o+n}a#=>{:a=>3,:b=>5,:

ruby-on-rails - 如何清理 Rails 4 中的原始 SQL

在Rails3中,我可以使用sanitize_sql_array为那些偶尔需要原始SQL查询的时刻清理原始SQL。但这似乎已在Rails4中删除,或者没有删除太多,而是移至ActiveRecord::Sanitization。但是,我现在不知道如何调用sanitize_sql_array,那么在Rails4中清理原始SQL的最佳方法是什么?我想澄清一下,我在这里谈论的是完整的原始SQL查询,而不是使用Rail的模型。我知道这不是最佳实践,这正是我必须为这个特定查询做的事情,因为它不能用Rails漂亮的ActiveRecord接口(interface)表示(相信我,我已经试过了)。这是一

sql - Ruby 中的 pretty-print SQL

有没有一种简单的方法可以在(rails3)控制台中pretty-print随机SQL?类似于awesome_print的内容,甚至可能是PrettyPrint.它不需要理解所有可能的方言或非常高级。我真正想要的是更轻松地检查ActiveRecord生成的SQL。目前我只是将SQL复制到网上进行格式化,这显然是生产力killer。我真的很想query.to_sql.pretty_format_sql并查看更好的输出。谢谢。 最佳答案 试试这个:gitclonehttps://github.com/sonota/anbt-sql-for